home *** CD-ROM | disk | FTP | other *** search
/ Libris Britannia 4 / science library(b).zip / science library(b) / DJGPP / CBGRX103.ZIP / contrib / libgrx / src / patfbox.c < prev    next >
Text File  |  1993-12-06  |  2KB  |  67 lines

  1. /**
  2.  ** PATFBOX.C
  3.  **
  4.  **  Copyright (C) 1992, Csaba Biegl
  5.  **    820 Stirrup Dr, Nashville, TN, 37221
  6.  **    csaba@vuse.vanderbilt.edu
  7.  **
  8.  **  This file is distributed under the terms listed in the document
  9.  **  "copying.cb", available from the author at the address above.
  10.  **  A copy of "copying.cb" should accompany this file; if not, a copy
  11.  **  should be available from where this file was obtained.  This file
  12.  **  may not be distributed without a verbatim copy of "copying.cb".
  13.  **  You should also have received a copy of the GNU General Public
  14.  **  License along with this program (it is in the file "copying");
  15.  **  if not, write to the Free Software Foundation, Inc., 675 Mass Ave,
  16.  **  Cambridge, MA 02139, USA.
  17.  **
  18.  **  This program is distributed in the hope that it will be useful,
  19.  **  but WITHOUT ANY WARRANTY; without even the implied warranty of
  20.  **  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  21.  **  GNU General Public License for more details.
  22.  **/
  23.  
  24. #include "grx.h"
  25. #include "libgrx.h"
  26. #include "clipping.h"
  27.  
  28. void GrPatternFilledBox(int x1,int y1,int x2,int y2,GrPattern *p)
  29. {
  30.     int width,height;
  31.     MOUSE_FLAG;
  32.  
  33.     CLIPBOX(CURC,x1,y1,x2,y2);
  34.     MOUSE_BLOCK(CURC,x1,y1,x2,y2);
  35.     width  = x2 - x1 + 1;
  36.     height = y2 - y1 + 1;
  37.     if(!p->gp_ispixmap)
  38.         while(--height >= 0) _GrFillPattern(x1,y1++,width,p);
  39.     else {
  40.         int pwdt = p->gp_pxp_width;
  41.         int phgt = p->gp_pxp_height;
  42.         int xoff = (x1 + CURC->gc_xoffset) % pwdt;
  43.         int yoff = (y1 + CURC->gc_yoffset) % phgt;
  44.         while(height > 0) {
  45.         int fillh   = MIN(height,(phgt - yoff));
  46.         int linewdt = width;
  47.         int xpos    = x1;
  48.         int xcuroff = xoff;
  49.         while(linewdt > 0) {
  50.             int fillw = MIN(linewdt,(pwdt - xcuroff));
  51.             _GrPixCopy(CURC,PIX_ADDR(CURC,xpos,y1),
  52.             (GC *)(&p->gp_pxp_source),PIX_ADDR(&p->gp_pxp_source,xcuroff,yoff),
  53.             fillw,fillh,p->gp_pxp_oper
  54.             );
  55.             linewdt -= fillw;
  56.             xpos += fillw;
  57.             xcuroff = 0;
  58.         }
  59.         height -= fillh;
  60.         y1 += fillh;
  61.         yoff = 0;
  62.         }
  63.     }
  64.     MOUSE_UNBLOCK();
  65. }
  66.  
  67.